.FormAssembly {
	width: 100%;
	max-height: 80vh;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;

	& > div {
		width: 100%;

		&.FormList {
			flex: 1;
			overflow-y: scroll;
			display: flex;
			align-items: flex-start;
			justify-content: flex-start;
			align-content: flex-start;
			flex-wrap: wrap;

			& > div {
				margin-bottom: 4px;

				&.FormHidden {
					display: none;
				}

				&.FormHalf {
					width: 46%;
					margin-left: 2%;
					margin-right: 2%;

					.ant-form-item-label {
						padding: 0;
					}
				}

				&.FormAll {
					width: 96%;
					margin-left: 2%;
					margin-right: 2%;

					.SelectIcon {
						display: flex;
						flex-wrap: wrap;
						align-items: flex-start;
						justify-content: flex-start;
						align-content: flex-start;
						background: white;
						height: 142px;
						background-image: none;
						border-width: 1px;
						border-style: solid;
						border-color: #d9d9d9;
						border-radius: 6px;
						padding: 4px 8px;
						overflow-y: scroll;

						& > div {
							padding: 4px 8px;
							cursor: pointer;
							border-radius: 8px;

							&:hover,
							&.active {
								background: #d9d9d9;
							}

							& > span {
								font-size: 24px;
							}
						}
					}
				}

				&.FormHelp {
					width: 96%;
					margin-left: 2%;
					margin-right: 2%;
					font-size: 18px;
					font-family: ShuHeiTi;
					font-weight: bold;
					text-align: center;
				}
			}
		}

		&.FormSub {
			display: flex;
			align-items: center;
			justify-content: center;
			margin: 16px 0 0 0;

			& > div {
				margin: 0;
			}

			.FormSubmit {
				width: 200px;
			}
		}
	}
}

input:invalid {
	animation: shake 0.2s ease-in-out 0s 2;
	box-shadow: 0 0 4px red;
}

@keyframes shake {
	0% {
		margin-left: 4px;
	}

	25% {
		margin-left: 8px;
	}

	75% {
		margin-left: -8px;
	}

	100% {
		margin-left: 4px;
	}
}
